package edu.scau.cxq.gp.mapper;

import edu.scau.cxq.gp.entity.Inventory;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import edu.scau.cxq.gp.vo.InventoryVO;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * <p>
 * 存储库存信息 Mapper 接口
 * </p>
 *
 * @author CXQ
 * @since 2022-01-30
 */
public interface InventoryMapper extends BaseMapper<Inventory> {

    /**
     * 获取最便宜的库存 以获最大的利益
     * @param goodsId
     * @param needs
     * @return
     */
    Inventory getLeastInventory (@Param("goodsId") Long goodsId, @Param("needs") Integer needs);

    /**
     * 获取所有的VO
     * @param goodsId
     * @param wareId
     * @return
     */
    List<InventoryVO> selectInventoryVOList(@Param("goodsId") Long goodsId, @Param("wareId") Long wareId);

    /**
     * 将仓库和货物及其价格相同的行整合起来
     */
    void addUpSameColumns();

    /**
     * 整理库存
     */
    void sortInventory();

    /**
     * 库存预警巡查
     */
    void findUnderThreshold (@Param("threshold") Integer threshold);
}
